package com.xizi.sort;

import java.util.Arrays;

public class BubbleSort {
    static int cnt = 1;

    public static void main(String[] args) {
        int[] arr = new int[]{5, 4, 3, 2, 1};
        System.out.println("排序前---------------------");
        System.out.println(Arrays.toString(arr));
        bubbleSort(arr);
        System.out.println("排序后---------------------");
        System.out.println(Arrays.toString(arr));
        System.out.println("交换的次数：" + cnt);

    }

    // 冒泡排序
    public static void bubbleSort(int[] arr) {
        for (int i = 0; i < arr.length - 1; i++) {
            //设定一个标记，若为true，则表示此次循环没有进行交换，也就是待排序列已经有序，排序已然完成。
            boolean flag = true;
            for (int j = 0; j < arr.length - 1 - i; j++) {
                if (arr[j] > arr[j + 1]) {
                    swap(arr, j, j + 1);
                    flag = false;
                }
            }
            if (flag) {
                break;
            }
        }
    }

    public static void swap(int[] arr, int a, int b) {
        cnt++;
        arr[a] = arr[a] + arr[b];
        arr[b] = arr[a] - arr[b];
        arr[a] = arr[a] - arr[b];
    }
}
